#两数相加
#您将得到两个表示两个非负整数的非空链表。数字以相反的顺序存储，每个节点包含一个数字。
# 添加这两个数字，并将其作为链接列表返回。
#您可以假定这两个数字不包含任何前导零，除了数字0本身。

class Solution:
    def addTwoNumbers(self, l1, l2):
        """
        :type l1: ListNode
        :type l2: ListNode
        :rtype: ListNode
        """
        # 两种特殊情况
        if l1 is None:
            return l2
        if l2 is None:
            return l1
        head = ListNode(0)
        l = head
        carry = 0
        # 当两个链表为空并且无进位，则退出循环
        while l1 or l2 or carry:
            # 每次循环开始，将进位给sum，并且进位清零
            sum, carry = carry, 0
            if l1 is not None:
                sum += l1.val
                l1 = l1.next
            if l2 is not None:
                sum += l2.val
                l2 = l2.next
            # 如果sum大于9，则进位
            if sum > 9:
                carry = 1
                sum -= 10
            # 创建新节点
            l.next = ListNode(sum)
            l = l.next
        return head.next